package com.xuetang.mapper;

import java.util.List;

import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

import com.xuetang.entity.ArticleFavorite;

/**
 * 文章收藏数据访问接口
 */
@Mapper
public interface ArticleFavoriteMapper {

    /**
     * 根据ID查询收藏记录
     */
    ArticleFavorite selectById(@Param("id") Long id);

    /**
     * 插入收藏记录
     */
    int insert(ArticleFavorite favorite);

    /**
     * 更新收藏记录
     */
    int updateById(ArticleFavorite favorite);

    /**
     * 删除收藏记录
     */
    int deleteById(@Param("id") Long id);

    /**
     * 查询用户是否收藏了某篇文章
     */
    int countByUserIdAndArticleId(@Param("userId") Long userId, @Param("articleId") Long articleId);

    /**
     * 查询用户收藏的文章ID列表
     */
    List<Long> selectArticleIdsByUserId(@Param("userId") Long userId);

    /**
     * 根据用户ID和文章ID删除收藏记录
     */
    int deleteByUserIdAndArticleId(@Param("userId") Long userId, @Param("articleId") Long articleId);

    /**
     * 根据用户ID查询收藏记录
     */
    List<ArticleFavorite> selectByUserId(@Param("userId") Long userId, @Param("offset") int offset,
            @Param("limit") int limit);

    /**
     * 统计用户收藏数量
     */
    int countByUserId(@Param("userId") Long userId);
}